Texture
や Sound
, Font
, GUI
などのアセットのハンドルに名前をつけ、名前を通してプログラムのどこからでもアクセスできるようにします。
プログラムでアセット管理を扱う手順は以下の通りです。
- アセットの「登録 (Register)」
- アセットの「プリロード (Preload)」(省略可能)
- アセットの「使用」
- アセットの「リリース (Release)」(省略可能)
- アセットの「登録解除 (Unregister)」(省略可能)
アセットをエンジンに登録します。
アセットの種類(テクスチャであるか、サウンドであるかなど)を関数で指定し、アセットに一意の名前をつけ、ファイル名やプロパティなどの情報を登録します。
この時点ではアセットデータは構築されないので、メモリの消費量が増えることはありません。
アセットデータを実際にロードします。
アセットの名前を指定すると、エンジンが該当アセットの登録時に与えられたファイル名やプロパティに従ってメモリにアセットデータを構築します。
指定されたアセットがすでにロードされている場合は何もしません。
アセットの名前を指定して、Texture 型や Sound 型のアセットハンドルを取得します。
このハンドルを使って、従来のアセットハンドルのように draw() したり、play() したりすることができます。
指定されたアセットが登録されていなかった場合は Null オブジェクトを返し、プリロードされていなかった場合はロードを実行してから結果のハンドルを返します。
アセットデータをメモリ上から解放します。
リリース後もアセットの登録情報は残っているため、再度プリロードしたり、使用したりすることができます。
一度ロードしたアセットをこの先しばらく使わず、メモリ消費を抑えたい場合にアセットのリリースをしましょう。
アセットの登録情報と名前をアセット管理から削除します。
該当アセットがリリースされていなかった場合はリリースします。
アプリケーション終了時にはすべてのアセットが自動でリリース、登録解除されるため、アセットの登録解除を明示的に行う必要はありません。
# include <Siv3D.hpp>
void Draw()
{
TextureAsset(L"picture").draw();
}
void Main()
{
TextureAsset::Register(L"picture", L"Example/Windmill.png");
while (System::Update())
{
Draw();
}
}
# include <Siv3D.hpp>
void Play()
{
SoundAsset(L"music").play();
}
void Main()
{
SoundAsset::Register(L"music", L"Example/風の丘.mp3");
Play();
while (System::Update())
{
}
}
# include <Siv3D.hpp>
void Draw()
{
FontAsset(L"font")(L"Hello, Siv3D!").draw();
}
void Main()
{
FontAsset::Register(L"font", 35, Typeface::Black);
while (System::Update())
{
Draw();
}
}
アセット作成フラグに AssetFlag::LoadImmediately
を指定すると、登録した時点で該当アセットをプリロードします。これによって、アセットの初回使用時の遅延を回避できます。
登録時にタグとなる文字列を指定し、同じタグを持つ複数のアセットを一括してロード、リリース、解除したりできるようになります。アセットには複数のタグを指定することができます。
アセット作成フラグに AssetFlag::TrackFile
を指定すると、アプリケーションの実行中に元のファイルが更新された場合、ロードしたアセットデータも自動的に更新されます。
Debug ビルドでは、アセットの作成と破棄がログファイルに記録されます。
TextureAssetData::FromFileArchive()
, SoundAssetData::FromFileArchive()
を使用すると、アーカイブファイルからアセットのロードが可能になります。